1時間プログラミング 011 JSONをCSVに変換する
#1時間プログラミング
概要
JSONをCSVに変換する
1時間プログラミング 010 CSVをJSONに変換するの逆バージョン
所要時間: 1時間
使い方
code:samples/liz-bluebird.json
[
{
"氏名": "鎧塚みぞれ",
"担当楽器": "オーボエ"
},
{
"氏名": "傘木希美",
"担当楽器": "フルート"
}
]
code:terminal
$ cat samples/liz-bluebird.json | deno run
氏名,担当楽器
鎧塚みぞれ,オーボエ
傘木希美,フルート
実装
TS(Deno)で作成する
標準入力から文字列を読み込む
1時間プログラミング_010_CSVをJSONに変換する#635e8e3a40fdcc00007021b9を参照
JSONからCSV用のデータに変換する
変換する形式は、の引数に合わせる
ヘッダーを指定する場合は、stringify(data, { headers: true, columns }) のようにオプションを指定する
dataにはCSV行の一覧を指定する
data: DataItem[]
ref.
columnsにはヘッダー列の一覧を指定する
columns: Column[]
ref.
各ヘッダー列には「列名 + プロパティ」or「プロパティ」を指定する
プロパティは、dataで指定したCSVデータのフィールドにアクセスするためのkeyという位置付け
「プロパティ」のみを指定した場合、列名はプロパティと同じになる
CSVのフィールドはdata[idx][<プロパティ>]で取得されるイメージ
code:ts
import { stringify } from "https://deno.land/std@0.161.0/encoding/csv.ts";
import { isPlainObject } from "https://deno.land/x/is_what@v4.1.7/src/index.ts";
function jsonToCsv(json: any): string {
// check type
if (!Array.isArray(json)) {
throw new Error("JSON is not array");
}
if (!json.every(isPlainObject)) {
throw new Error("JSON item is not object");
}
// get keys
const keySet = new Set<string>();
json.forEach((obj) => {
Object.keys(obj).forEach((k) => keySet.add(k));
});
const columns = Array.from(keySet);
// convert
const data = json.map((obj) => {
return columns.reduce((row, k) => {
return { ...row, k: objk ?? "" };
}, {});
});
return stringify(data, { headers: true, columns });
}
型チェックはあまり厳密に行っていない
厳密に見るなら、CSVフィールドの値は数値・文字列・真偽値・nullのみ許可すべき
感想
の挙動がよく分からず、ソースコードを読んで確認した